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(54) Tide: A FAST FREQUENCY TRANSFORMATION TECHIQUE FOR TRANSFORM AUDIO CODERS 



(57) Abstract 

A method for coding digital audio data in 
which coded Fast Modified Discrete Cosine Trans- 
form (FMDCT) coefficients are computed utilising 
a Fast Fourier Transform (FFT) method. The de- 
scribed method allows a significant reduction in 
computations as compared to an ordinary DCT cod- 
ing procedure. Also, pairs of audio channels can be 
combined to use a single FFT computation, where 
the selected transform length for the paired channels 
is the same. In such cases where pairing of identi- 
cal transform length channels is not possible, a long 
transform length channel is combined with a short 
transform length channel and converted in two short 
transforms. A windowing function is also combined 
with a pre-processing stage to the transformation, 
further decreasing computational requ ireemen ts. 
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A FAST FREQUENCY TRANSFORMATION TECHNIQUE 
FOR TRANSFORM AUDIO CODERS 

Technical Field 

5 

This invention is applicable in the field of multi-channel audio coders which use modified 
discrete cosine transform as a step in the compression of audio signals. 

Background Art 

10 

In order to more efficiently broadcast or record audio signals, the amount of information 
required to represent the audio signals may be reduced. In the case of digital audio 
signals, the amount of digital information needed to accurately reproduce the original 
pulse code modulation (PCM) samples may be reduced by applying a digital compression 
15 algorithm, resulting in a digitally compressed representation of the original signal. The 
goal of the digital compression algorithm is to produce a digital representation of an audio 
signal which, when decoded and reproduced, sounds the same as the original signal, while 
using a minimum of digital information for the compressed or encoded representation. 

20 Recent advances in audio coding technology have led to high compression ratios while 
keeping audible degradation in the compressed signal to a minimum. These coders are 
intended for a variety of applications, including 5. 1 channel film soundtracks, HDTV, 
laser discs and multimedia. Description of one applicable method can be found in the 
Advanced Television Systems Committee (ATSQ Standard document entitled "Digital 

25 Audio Compression (AC-3) Standard", Document A/52, 20 December, 1995. 

In the basic approach, at the encoder the time domain audio signal is first converted to the 
frequency domain using a bank of filters. The frequency domain coefficients, thus 
generated, are converted to fixed point representation. In fixed point syntax, each 
30 coefficient is represented as a mantissa and an exponent. The bulk of the compressed 
bitstream transmitted to the decoder comprises these exponents and mantissas. 
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The exponents are usually transmitted in their original form. However, each mantissa 
must be truncated to a fixed or variable number of decimal places. The number of bits to 
be used for coding each mantissa is obtained from a bit allocation algorithm which may be 
based on the masking property of the human auditory system. Lower numbers of bits 
5 result in higher compression ratios because less space is required to transmit the 
coefficients. However, this may cause high quantization errors, leading to audible 
distortion. A good distribution of available bits to each mantissa forms the core of the 
advanced audio coders. 

10 The frequency transformation phase has one of the greatest computation requirements in a 
transform coder. Therefore, an efficient implementation of this phase can decrease the 
computation requirement of the system significantly and make real time operation of the 
encoder more easily attainable. 

15 In some encoders such as those specified in the AC-3 standard, the frequency domain 
transformation of signals is performed by the modified discrete cosine transform (MDCT). 
If directly implemented, the MDCT requires 0(N*) additions and multiplications. 
However it has been found possible to reduce the number of required operations 
significandy if the MDCT equation is able to be computed in a from that is amenable to 

20 the use of the well known Fast Fourier Transform (FFT) method of J.W. Cooley and J.W. 
Tukey (1960). Moreover, using a single FFT for two channels can result in greater 
reduction in computational requirements of the system. 

Summary of the Invention 

25 

In accordance with the present invention there is provided a method for coding audio data 
comprising a sequence of digital audio samples, including the steps of: 

i) multiplying the input samples with a first trigonometric function factor to 
generate an intermediate sample sequence; 
30 ii) computing a fast Fourier transform of the intermediate sample sequence to 

generate a Fourier transform coefficient sequence; 
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iii) for each transform coefficient in the sequence, multiplying the real and 
imaginary components of the transform coefficient by respective second trigonometric 
function factors, adding the multiplied real and imaginary transform coefficient 
components to generate an addition stream coefficient, and subtracting the multiplied real 

5 and imaginary transform coefficient components to generate a subtraction stream 
coefficient; 

iv) multiplying the addition and subtraction stream coefficients with respective 
third trigonometric function factors; and 

v) subtracting the corresponding multiplied addition and subtraction stream 
10 coefficients to generate audio coded frequency domain coefficients. 

The present invention also provides a method for coding audio data, including the steps 
of: 

combining first and second sequences of digital audio samples from first and 
15 second audio channels into a single complex sample sequence; 

determining a Fourier transform coefficient sequence as defined above; 
generating first and second transform coefficient sequences by combining and/or 
differencing first and second selected transform coefficients from said Fourier transform 
coefficient sequence; and 
20 for each of the first and second transform coefficient sequences, generating audio 

coded frequency domain coefficients as defined above, so as to generate respective 
sequences of said audio coded frequency domain coefficients for the first and second audio 
channels. 

25 The present invention also provides a method for coding audio data including the steps of: 

obtaining at least one input sequence of digital audio samples; 

pre-processing the input sequence samples including applying a pre-multiplication 
factor to obtain modified input sequence samples; 

transforming the modified input sequence samples into a transform coefficient 
30 sequence utilising a fast Fourier transform; and 

post-processing the sequence of transform coefficients including applying first post- 
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multiplication factors to the real and imaginary coefficient components, differencing and 
combining the post-multiplied real and imaginary components, applying second post- 
multiplication factors to the difference and combination results, and differencing to obtain 
a sequence of modified discrete cosine transform coefficients representing said input 
5 sequence of digital audio samples. 

The present invention also provides a method for coding audio data including the steps of: 

obtaining first and second input sequences of digital audio samples corresponding 
to respective first and second audio channels; 

10 combining the first and second input sequences of digital audio samples into a 

single complex input sample sequence; 

pre-processing the complex input sequence samples including applying a pre- 
muitiplication factor to obtain modified complex input sequence samples; 

transforming the modified complex input sequence samples into a complex 

15 transform coefficient sequence utilising a fast Fourier transform; and 

post-processing the sequence of complex transform coefficients to obtain first and 
second sequences of audio coded frequency domain coefficients corresponding to the first 
and second audio channels including, for each corresponding frequency domain coefficient 
in the first and second sequences, selecting first and second complex transform coefficients 

20 from said sequence of complex transform coefficients, combining the first complex 
transform coefficient and the complex conjugate of the second complex transform 
coefficient for said first channel and differencing the first complex transform coefficient 
and the complex conjugate of the second complex transform coefficient for said second 
channel, and applying respective post-multiplication factors to the combination and 

25 difference to obtain said audio coded frequency domain coefficients corresponding to the 
first and second audio channels. 

The present invention further provides A method for coding audio data including the steps 

of: 

30 obtaining first and second input sequences of digital audio samples x[n], y[n] 

corresponding to respective first and second audio channels; 
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combining the first and second input sequences of digital audio samples into a 
single complex input sample sequence z[n], where z[n] = x[n] + jy[n]> 

pre-processing the complex input sequence samples including applying a pre- 
multiplication factor cos{7tn/N) + jsin{im/N) to obtain modified complex input sequence 
5 samples, where N is the number of audio samples in each of the first and second input 
sequences and n = 0 ,(AM); 

transforming the modified complex input sequence samples into a complex 
transform coefficient sequence Z k utilising a fast Fourier transform, wherein k = 
0 ,(W2-1); and 

10 post-processing the sequence of complex transform coefficients to obtain first and 

second sequences of audio coded frequency domain coefficients corresponding to the first 
and second audio channels X k , Y k according to: 

G k - (Z^Z^ fcM )/2 A=0.JW2-1 
G\ = (Z k -Z^ k _ x )I2j *=0.JV72-l 

X k = cosy * ^cos(7t(Ar+l/2)/JV)^sin(ii(A:+l/2)/A0 

- siny * (g^sin(K(/:+l/2)/A^+^.cos()t(/:+l/2)/A0 

Y k - cosy * ^cos^^^l^y^^sinCTt^+l^)/^ 

- siny * (^ v sin(7c(A^l/2)/A^^cos(n(it+l/2)/iV) 

15 where G k is a transform coefficient sequence for the first channel; 

G\ is a transform coefficient sequence for the second channel; 

g^ r and g ki are the real and imaginary transform coefficient components of G k \ 

g' kr and g\ t are the real and imaginary transform coefficient components of G k \ 

ZV*w is the complex conjugate of Z m ^\ and 
20 y(Jfc) = rc(2A:+l)/4. 

The modified discrete cosine transform equation can be expressed as 
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x k = E *M * cos(2nK2»+lM2JM)/4tf + ir*(2*+i)/4) **0...(JV72-1) 

where jc/h/ is the input sequence for a channel and N is the transform length. 

Instead of evaluating X k in the form given above it could be computed as 

X k = cosY*^cos(Tt(^^l/2yA0^,sm(it()t+l/2)/A0) 
-siny *fe Jt/ .sin(7t(£+ \I2)IN) +g w cos(ic(*+ 1/2)///)) 
g^jy e 5R(^e/ of mar/ numbers) 

where ■ * yg^ = £ (^[n]e jMtM )ie J2miliai . The symbol j represents the 

5 imaginary number ^-T . The expression £ (x[*]e^^)*e ;2 *^ is obtained from 

the well known FFT method, by first using transformation x 9 [n]=x[n] * and then 
computing the FFT G k = x\n]*e J2tum . 

For a two channel approach, a complex variable z[n] = x[n]^e Jm/N + j$ii\*e lmai is 
10 defined, where Jt[n] and y[n] are sample sequence for the two channels and e Jmt/N 

represents the pre-rnultiplication factor. Using FFT approach, the frequency coefficient Z k 
for the variable z[n] is computed. From Z k the value G k « (Z k + Z^)I2 and G * - 
Z*^)/2/, required to compute the final MDCT for each channel, respectively, is 
calculated. 

15 

If either or both the channels require short length transformers, two short transforms are 
taken using the above approach. If neither need short transform, a single long transform 
is used. As an additional step in reducing computation, the windowing function can be 
combined with the pre-processing stage. 
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Brief Description of the Drawings 

The invention is described in detail hereinafter, by way of example only, with reference to 
preferred embodiments thereof and with aid of the accompanying drawings, wherein: 
5 Figure 1 is a diagrammatic representation of a stream of audio data and the 

substructure arrangement thereof; 

Figure 2 is a functional block diagram of a digital audio encoder; 

Figure 3 is a functional block diagram of a system for encoding a single audio 
channel; and 

10 Figure 4 is a functional block diagram of a system for encoding a pair of audio 

channels. 

Detailed Description of the Preferred Embodiments 

15 The above mentioned Advanced Television Systems Committee (ATSQ Standard 
document entitled "Digital Audio Compression (AC-3) Standard" (Document A/52, 20 
December, 1995) describes methods for encoding and decoding audio signals, and is 
hereby expressly incorporated herein by reference. 

20 In general, the input to an audio coder comprises a stream of digitised samples of the time 
domain analog signal. For a multi-channel encoder the stream consists of interleaved 
samples for each channel. The input stream is sectioned into blocks, each block 
containing N consecutive samples of each channel (see Fig. 1). Thus within a block the N 
samples of a channel form a sequence (x[0], x[l]> x[2]> x[N-l}}. 

25 

The time domain samples are next converted to the frequency domain using an analysis 
filter bank (see Fig. 2). The frequency domain coefficients, thus generated, form a 
coefficient set which can be identified as (X 0 , X v X 2 , X m-l ). Since the signal is real 
only the first Nil frequency components are considered. Here X<, is the lowest frequency 
30 (DC) component while X N/2 .i is the highest frequency component of the signal. 
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Audio compression essentially entails finding how much of the information in the set (X 0 , 
X„ X 2 , X mA ) is necessary to reproduce the original analog signal at the decoder with 
minimal audible distortion. 

5 The coefficient set is normally converted into floating point format, where each coefficient 
is represented by an exponent and mantissa. The exponent set is usually transmitted in its 
original form. However, the mantissa is truncated to a fixed or variable number of 
decimal places. The value of number of bits for coding a mantissa is usually obtained 
from a bit allocation algorithm which for advanced psychoacoustic coders may be based 
10 on the masking property of the human auditory system. A low number of bits results in 
high compression ratio because less space is required to transmit the coefficients. 
However this causes very high quantization error leading to audible distortion. A good 
distribution of available bits to each mantissa forms the core of the most advanced 
encoders. 

15 

In some encoders such as the AC-3, the frequency domain transformation of signals is 
performed by the (MDCT) modified discrete cosine transform (Eq. 1). 

*k 58 £ *M * cos(2K*(2n+l)*(2A+l)/4^ ♦ K*(2JM)/4) JML.(M2-1) Eq. 1 

If directly implemented in the form given above, the MDCT requires 0(N*) additions and 
multiplications. 

20 

Single Channel FFT 

It is possible to reduce the number of required operations significantly if one is able to 
25 evaluate Eq. 1 using the well known Fast Fourier Transform method of J.W. Cooley and 
J.W. Tukey (1960). The general Discrete Fourier Transform (DFT) is given below (Eq. 
2). It requires 0(N*) complex additions and multiplications. By using the Fast Fourier 
Transform method the DFT in Eq. 2 can be computed with 0(Mog2N) operations only. 
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F k = J2 <x[n]*e z *"*"') k=0..X-l Eq. 2 

rt»0 

Here j is the symbol for imaginary number, i.e. j » /■/. 

Although it may not be immediately apparent how Eq. 1 can be transformed to Eq. 2, a 
careful analysis shows that this is indeed possible. To simplify Eq. 1, two functions can 
5 be defined 

a(n,k) = 2k(2/i + 1)(2*+1)/4N ' Eq. 3 

y(k) m %(2k+l)/4 Eq. 4 

Then, using these functions, Eq. 1 can be rewritten as 



L *M*cos(a(/i,*)+Y(*)) Eq.5 
= £ ^[w3*(cosa(/i,*)cosY(*)-sina(/i,*)sinY(A)) E( lv 5 



n=0 



10 In Eq. 6 the trigonometric equality, cos(a+6) = cosa cosfc-sina sinZ? is used for 

simplification. Furthermore, since the function y(k) is not dependant on variable n, it can 
be brought outside the summation expression to give 

X k = cosy(A) x[n]*cosa(/i,A) - sinY(*) £ *[*] *sina(/i,*) 

= T t co$y(k) - T 2 %\ny{k) Eq. 7 



where jT, * £ *["] *cosa(/t,A) and f 2 = J x[*]*sina(n,*) 



The two terms, T t and T 2 , can now be evaluated separately. Using Euler's identity e m 
15 cos6 +ysin0, we can express: 

cosa(/!,*)«(e* ,a > + e^^tf 
and sincc(*, k) = (e^-e^^y. 
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Therefore we can rewrite the term T, as 

T x = E *[n)*(e**e->*)/2 = l/2( £ x[n]*<?'° + E 

n=0 /rt>0 /i=0 

= 1/2 (X, + 



where 4, = 52 and A 2 = £ *M*e"* 

fF=0 /f=0 



Similarly 



a=tf-l «=A/-| /r=A/~ 1 

^ s £ "*y2 - 1/2/( X) *M** ;a - ^ jc[/i] 

= 1/2/04, - A 2 ) 



Eq. 8 



Eq. 9 



The term 4, can thus be evaluated from Eq. 8 and Eq. 9 

n=AM 

A = E *M*«* 

n=0 

= ]C x[/i]*e A2n(2n * I)(2J,ri ' iy4A/) 

n=o Eq. 10 

5 If a complex variable is defined as: 

jc , [n]=4n]*e i *°' N Eq. 11 

then Eq. 10 is simply: 

Eq.i2 



where C A = E *1»]*e ,2 ** w 
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The complex term G k = g k . r +g k .j, where g k>r and g ti e 91 (set of real numbers) in Eq. 12 is 
essentially the same as F k in Eq. 2. Therefore the FFT approach can be used to evaluate 
G k . This brings down computation from OiN 1 ) to O(NiogN). Similarly, the second term 
Aj in Eq. 8 and Eq. 9 can be evaluated 



Note that G k " is actually the complex conjugate of G k which was obtained by Eq. 12. That 
is, if G k = gic.r+gu. where g k r and g^ e 31 as defined earlier, then G k * = g k , r - y'g k>i . 
Therefore G k * in Eq. 13 does not need to be computed again, and the result from Eq. 12 
can be re-used. That is, only one FFT needs to be computed for the evaluation of 7,. 
10 The result of Eq. 8 to Eq. 13 is thus 




-j2nrtk/N 




Eq. 13 



5 where G k ' = £ (x[n] *e -* n,N ) *e - j2Knm 



r, = \/2(e^ lf2)W G k +e -M^wy* 



Eq. 14 



Next, the term T : can be analysed 



r 2 = £ m*(^-e-^/2j 



= V2j(A r A 2 ) 



= \/2j(eM" in W G k -e'^ m)IN G k ') 



Eq. 15 



Finally, after simplifications of Eq. 7, 14 and 15 
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X k = cosyW \ll(e^ m)fN G k +e->* {k - xa)fN G k ) 

a cosy * (^/os(x(*+l/2)/A0-g^stn(Tt(/:+I/2)/A0 
- siny * (g^sin(it()fc*l/2)/A0+^cos(Ti(A+l/2)/A0 
= cosy * T x - siny * T 2 Eq i 6 

The term G k = g Kr + jg Kl is computed in 0(N\ogN) operation by use of FFT algorithms. 
The additional operation outlined in Eq. 16 to extract the final X k is only of order O(N). 
Therefore the MDCT can now be computed in 0(Nlog 2 N) time. The operations required 
to obtain the MDCT are illustrated in Fig. 3. 

5 

Combining Two Channels into Single FFT 

Suppose the multi-channel encoder is required to process m audio channels. Instead of 
computing an FFT for each channel as described in the previous section, it is possible to 
10 further reduce the computational requirement of the coder by combining two channels and 
using a single FFT only. In effect, instead of m FFTs only mil FFTS need to be 
computed. 

If the input sequence are real numbers then it is known that DFT for any two channels can 
15 be computed with only one FFT block by considering the input as a complex number. 
The real pan is formed from the sequence for any one channel and the imaginary part is 
from data of another channel. After the Fourier Transform is computed for the resulting 
complex variable, the resulting transform for each channel can be easily retrieved. 

20 However, in the present case the input data to the FFT block is actually a complex number 
(formed by multiplying the real data by complex variable e imUH ). In this case, there is no 
straightforward way of retrieving the frequency transform after having combined two 
channels. However, using some processing after the FFT one can still compute the DFT 
of two channel using a single FFT block. 

25 



I * 
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Let {jc[0J^c[1J^c(2],.., kC[N-1]} be N input samples of the first channel and 
{y[0],y[l),y[2],...y[N-l]} be the samples for the second channel. As described above, the 

frequency coefficients G k = £ x[n]e J1u " N * e j2nnk/N (Eq. 12 and 13) must be 
obtained for the first channel; and similarly, for the second channel 

Defining complex variable z[n] = x[n]*e i ^ + jy[n]*e? nafS Eq. 17 

and computing its DFT using the FFT method, yields 

#1=0 Eq. 18 

Now substituting N-k for in the above expression, 

n=o Eq. 19 

Since e 12 ™ « 1, n € I (the set of integers), the term d z ™ vanishes in the above expression. 
10 Taking the complex conjugate of Z^: 

««o Eq. 20 
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Using Eq. 18 and 20, separate expressions for G k and G' k are required. In a simple case 
the conjugates in Eq. 18 and 20 should add and subtract to give the required expressions. 
However in this instance that is not the case. But, substituting N~k by N-k-1 in Eq. 18, the 
following is obtained 

5 Now the term e* 2 **** 1 ^'* is common in both Eq. 17 and 19, and it is possible to isolate. 



+ Cj2 x[n]*e' 2n * k + iavN -j Y;y[n]*E j2ntt(krXavN ) 
= 2G k 



Similarly, 



n=AM 
/i*0 

■ 



That is 



G fc = (V z /J-*-i) /2 k=Q..m-\ Eq. 22 



and 



10 



Eq. 23 
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From the expression from Eq. 22 and 23 into Eq. 16, the MDCT for each channel is 
obtained. The overall process is illustrated in Fig. 4. 



Transform Length Adjustment Technique 

5 

The frequency transform length N is decided by the encoder based on temporal and 
spectral resolution requirements. The input signal is usually analysed with a high 
frequency bandpass filter to detect the presence of transients. This information is used to 
adjust the block length, restricting quantization noise associated with the transient within a 
10 small temporal region about the transient, avoiding temporal masking. Thus, if transient 
is detected in a channel, two short transform of length N/2 each are taken. In the absence 
of transient, a single long transform of length N is used, thus providing higher spectral 
resolution. 



15 From the method described in the previous section for computing MDCT for two channels 
using a single FFT block, it is evident that the transform length for the two paired 
channels must be the same. Therefore, pairing for the transformation phase much be such 
that channels with identical transform length are grouped together. 

20 It is however possible that not all channels can be paired with such convenience. Assume 
that the total number of channels are an even number (if not, take a single FFT for one 
channel and the rest form an even group). Suppose out of the m channels, / need long 
transform and therefore m-l require short transform. 

25 If / is an even number, then since the total is even, it follows that l-m is also even. In this 
case, from the / channels that need long transform, 1/2 pairs are formed and for each of 
the 1/2 pairs a single FFT is computed to estimate the MDCT for the original paired 
channels. Similarly, the l-m channels are paired to form (l-m)/2 pairs and for the (/-m)/2 
pairs two short FFTs are computed. 

30 

Now consider the case when 1 / = 2r + I is an odd number. Therefore m - 1 = 2s + 1 is 
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also an odd number. The 2r channels requiring long transform are paired together to form 
r pairs and then 2r transforms are computed using r FFTs only. Similarly, for the 2s 
channels s pairs are formed. What remains is one channel requiring long transform and 
another requiring two short transforms. Both of these channels are paired together and 
5 two short FFTs are computed to derive the MDCT. 

The rationale for constraining the long transform to two short ones is as follows. A short 
transform is required for restricting quantization noise associated with the transient within 
a small temporal region about the transient, avoiding temporal masking. A long transform 
10 gives slight better frequency resolution but the error is not much compared to the case 
when in the presence of transient a long transform is utilised. Forcing a long transform 
onto a channel in the presence of transient leads to greater distortion in the final produced 
music. This conjecture was proven true by experimental studies on benchmark music 
streams. 

15 

Combining Windowing with pre-processing 

Before the time domain signal x[n] is transformed to the frequency domain, a windowing 
function is usually applied. Thus, if the sampled signal is p[n] then the sequence that is 
20 applied to the frequency transformation block is x[n] = p[n] * w[ri\, where w[n] is the 
windowing function. From the previous sections we noted that before the FFT is 
computed for a block a pre-processing is performed as given in Eq. 1 1 (reproduced below 
for convenience). Thus 

x'[n] =x[n] * e Jm/N 
25 m (p[n}*w[n])* e JmUN 

= (p[n]* h>[/i])* (cosot/AT -f j sin mi/N) 

= p[n] * ({w[n] * cosjm/N) + y(vv[n]*sin;m/iV)) Eq. 24 

From Eq. 24 we note that the windowing function can be combined with the cosine and 
30 sine multiplication required in Eq. 11. This brings down the computation even further 
since the sine and cosine are usually implemented in a real time system as table-lookup. If 



* 
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two tables are constructed as defined below 



rcos[n] = w[n] * cos( an/AO 
rsin[n] - w[/z]* s\n(m/N) 

5 

then Eq. 1 1 can be rewritten as 



x*[n] a (/?[*] * rcos[n]) + r sin [n]) Eq. 25 

10 Although the invention has been described herein primarily in terms of its mathematical 
derivation and application, and the procedures required for implementation, it will be 
readily recognised by those skilled in the art that the procedures described can be 
implemented by means of any desired computational apparatus. For example, the 
invention may be embodied in computer software operating on general purpose computing 

15 equipment, or may be embodied in purpose built circuitry or contained in microcode or 
the like in an integrated circuit or set of integrated circuits. 



20 



The foregoing detailed description of embodiments of the invention has been presented by 
way of example only, and is not intended to be considered limiting to the invention as 
defined in the claims appended hereto. 
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Glossary of Equations: 



MDCT 

X k = E *M * cos(2jr*(2«+l)*(2A:+l)/4iV + tc*(2At+1)/4) k=Q...(NI2-\) 

i»*0 

= cosy * Cg' fc>r cos(n(/:+l/2)/A0-^sin(ir(Ar+l/2)/A0 
- siny * (g^ r sia(it(k+V2)/N)*g^cos(n(k*\/2)/N) 
= r,cosY(/t) - T 2 smy(k) 

T \ = E *[«]*coscc(n,A) r 2 = J) x[«]*sina(/t,A:) 



^, = E *M** /8 ^2 - E *M*« _J * 



C * = "e' (*M * eS *""*) * eJ2,uMN G k ' = "ff (x[n) *e *e ^ aMr 



G k = (Z k +Z A ;. fc . 1 )/2 k=0.MI2-\ 

10 G' k = iZ k -Z^. k . x )l2j Jfc=0..JV/2-l 

a(/i,Jfc) = 2^(2n+ l)(2Jt+l)/4N 
Y(/t) = Ti(2jfc+l)/4 
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Claims 

1, A method for coding audio data comprising a sequence of digital audio samples, 
including the steps of: 

5 i) multiplying the input samples with a first trigonometric function factor to 

generate an intermediate sample sequence; 

ii) computing a fast Fourier transform of the intermediate sample sequence to 
generate a Fourier transform coefficient sequence; 

iii) for each transform coefficient in the sequence, multiplying the real and 
10 imaginary components of the transform coefficient by respective second trigonometric 

function factors, adding the multiplied real and imaginary transform coefficient 
components to generate an addition stream coefficient, and subtracting the multiplied real 
and imaginary transform coefficient components to generate a subtraction stream 
coefficient; 

15 iv) multiplying the addition and subtraction stream coefficients with respective 

third trigonometric function factors; and 

v) subtracting the corresponding multiplied addition and subtraction stream 
coefficients to generate audio coded frequency domain coefficients. 

20 2. A method for coding audio data as claimed in claim 1, wherein the audio coded 
frequency domain coefficients comprise modified discrete cosine transform coefficients. 

3. A method for coding audio data as claimed in claim 1 or 2, wherein the first 
trigonometric function factor for each audio sample is a function of the audio sample 

25 sequence position and the number of samples in the sequence. 

4. A method for coding audio data as claimed in claim 3, wherein the respective 
second trigonometric function factors for each transform coefficient in the sequence are 
respective functions of the transform coefficient sequence position and the number of 

30 coefficients in the sequence. 
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5. A method for coding audio data as claimed in claim 4, wherein the respective third 
trigonometric function factors are respective functions of the transform coefficient 
sequence position. 

5 6. A method for coding audio data as claimed in claim 5, wherein step i) comprises 
multiplying the input sequence samples xfnj by the first trigonometric function factor 
cos(7tn/N) to generate the intermediate sample sequence, where: 
xfnj are the input sequence audio samples; 
N is the number of input sequence audio samples; and 
10 n = 0,....,M7. 



7. A method for coding audio data as claimed in claim 6, wherein step ii) comprises 
computing the fast Fourier transform of the intermediate sample sequence so as to generate 
said transform coefficient sequence G k — g Kr + jg Kh where: 
15 G k is the transform coefficient sequence; 

g Kr are the real transform coefficient components; 

g Ki are the imaginary transform coefficient components; and 

Jfc = 0,....,(M2-i). 



20 8. A method for coding audio data as claimed in claim 7, wherein step iii) comprises 
determining the addition stream coefficients T 2 and subtraction stream coefficients T : 
according to: 

T l = g Kr cos(n(k+l/2)/N) - g Kl sin(7r(k+l/2)/N) 
T 2 » g kf cos(ir(k+l/2)/N) + guSin(7r(k+l/2)/N) 
25 where T t and T 2 are the subtraction stream and addition stream coefficients, respectively. 

9. A method for coding audio data as claimed in claim 8, wherein steps iv) and v) 
comprise generating the audio coded frequency domain coefficients X k according to: 
X k = T t cos(7r(2k+l)/4) - T 2 sin(7r(2k+!)/4) 
30 where X k are the audio coded frequency domain coefficients; and 

cos(:r(2k+l)/4) and sin(7z(2k+l)/4) are the third trigonometric function factors. 
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10. A method for coding audio data, including the steps of: 

combining first and second sequences of digital audio samples from first and 
second audio channels into a single complex sample sequence; 

determining a Fourier transform coefficient sequence as defined in any preceding 

5 claim; 

generating first and second transform coefficient sequences by combining and/or 
differencing first and second selected transform coefficients from said Fourier transform 
coefficient sequence; and 

for each of the first and second transform coefficient sequences, generating audio 
10 coded frequency domain coefficients as defined in any preceding claim, so as to generate 
respective sequences of said audio coded frequency domain coefficients for the first and 
second audio channels. 

11. A method for coding audio data as claimed in claim 10, wherein the step of 
15 generating first and second transform coefficient sequences comprises, for each 

corresponding coefficient in the first and second transform coefficient sequences, selecting 
first and second transform coefficients from said Fourier transform coefficient sequence, 
determining a complex conjugate of said second transform coefficient, combining said first 
transform coefficient and said complex conjugate for said first transform coefficient 
20 sequence and differencing said first transform coefficient and said complex conjugate for 
said second transform coefficient sequence. 

12. A method for coding audio data as claimed in claim 10 or 1 1, wherein the 
multiplying step i) comprises multiplying the input sequence samples z[n] by the first 

25 trigonometric function factor cos(m/N) + jsinfm/N) to generate the intermediate sample 
sequence, where: 

z[n] - x[n) + jy[n] is the complex sample sequence; 

x[n] is the first sequence of digital audio samples; 

y[n) is the second sequence of digital audio samples; 
30 N is the number of input sequence audio samples in each sequence; 

n = 0,. ...,#-/; and 
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j is the complex constant. 

13. A method for coding audio data as claimed in claim 11 or 12, wherein said first 
and second transform coefficient sequences are generated according to: 
5 G, = (Z, + ZW,)/2 

where G k is said first transform coefficient sequence; 

G\ is said second transform coefficient sequence; 
N is the number of input sequence audio samples; 
10 k * 0,....,(N/2-l); 

2 k is said first transform coefficient; 

ZV-*./ is the complex conjugate of said second transform coefficient; and 
j is the complex constant. 

15 14. A method for coding audio data as claimed in any one of claims 10 to 13, 

including examining said first and second sequences of digital audio samples to determine 
a short or long transform length, and coding the audio samples using a short or long 
transform length as determined. 

20 15. A method for coding audio data comprising sequences of digital audio samples 
from a plurality of audio channels, comprising determining a transform length for each of 
the channels, pairing the channels according to their determined transform length, and 
coding the audio samples of first and second channels in each pair, as defined in any one 
of claims 10 to 13, according to the determined transform length. 

25 

16. A method for coding audio data as claimed in any preceding claim, including 
applying a windowing function in combination with said multiplying step i). 

17, A method for coding audio data including the steps of: 

30 obtaining at least one input sequence of digital audio samples; 

pre-processing the input sequence samples including applying a pre-muitipiication 



WO 99/43110 



PCT/SG98/00014 



-23- 

factor to obtain modified input sequence samples; 

transforming the modified input sequence samples into a transform coefficient 
sequence utilising a fast Fourier transform? and 

post-processing the sequence of transform coefficients including applying first post- 
5 multiplication factors to the real and imaginary coefficient components, differencing and 
combining the post-multiplied real and imaginary components, applying second post- 
multiplication factors to the difference and combination results, and differencing to obtain 
a sequence of modified discrete cosine transform coefficients representing said input 
sequence of digital audio samples. 

10 

18. A method as claimed in claim 17, wherein the pre-multiplication factor, and first 
and second post-multiplication factors are trigonometric function factors. 

19. A method as claimed in claim 18, wherein the pre-multiplication factor applied to 
15 each digital audio sample in the input sequence is a trigonometric function of the audio 

sample sequence position and the number of samples in the sequence. 

20. A method as claimed in claim 18, wherein the first post-multiplication factors for 
each transform coefficient in the sequence are trigonometric functions of the transform 

20 coefficient sequence position and the number of coefficients in the sequence. 

21. A method as claimed in claim 18, wherein the second post-multiplication factor for 
each difference or combination result is trigonometric functions of the transfoim 
coefficient sequence position of the coefficients used in the difference or combination. 

25 

22. A method as claimed in any one of claims 17 to 21, wherein the pre-processing 
operations are performed on each sample in the input sequence individually. 

23. A method as claimed in any one of claims 17 to 22, wherein the post-processing 
30 operations are performed on each transform coefficient in the sequence individually. 
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24. A method for coding audio data including the steps of: 

obtaining first and second input sequences of digital audio samples corresponding 
to respective first and second audio channels; 

combining the first and second input sequences of digital audio samples into a 
5 single complex input sample sequence; 

pre-processing the complex input sequence samples including applying a pre- 
multiplication factor to obtain modified complex input sequence samples; 

transforming the modified complex input sequence samples into a complex 
transform coefficient sequence utilising a fast Fourier transform; and 
10 post-processing the sequence of complex transform coefficients to obtain first and 

second sequences of audio coded frequency domain coefficients corresponding to the first 
and second audio channels including, for each corresponding frequency domain coefficient 
in the first and second sequences, selecting first and second complex transform coefficients 
from said sequence of complex transform coefficients, combining the first complex 
15 transform coefficient and the complex conjugate of the second complex transform 
coefficient for said first channel and differencing the first complex transform coefficient 
and the complex conjugate of the second complex transform coefficient for said second 
channel, and applying respective post-multiplication factors to the combination and 
difference to obtain said audio coded frequency domain coefficients corresponding to the 
20 first and second audio channels. 

25. A method as claimed in claim 24, wherein the pre-multiplication factor for each 
sample in the complex input sample sequence comprises a complex trigonometric function 
of the complex input sample sequence position and the number of samples in the sequence. 

25 

26. A method as claimed in claim 24 or 25, wherein the post-processing for each of the 
first and second channels includes applying first post-multiplication factors to the real and 
imaginary coefficient components, differencing and combining the post-multiplied real and 
imaginary components, applying second post-multiplication factors to the difference and 

30 combination results, and differencing to obtain a sequence of modified discrete cosine 
transform coefficients representing said input sequence of digital audio samples. 



« 
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27. A method for coding audio data including the steps of: 

obtaining first and second input sequences of digital audio samples yW 

corresponding to respective first and second audio channels; 

combining the first and second input sequences of digital audio samples into a 
5 single complex input sample sequence z[n] y where z[n] = x[n] + jy[n}; 

pre-processing the complex input sequence samples including applying a pre- 

multiplication factor cos(7tn/N) + jsin{7tn/N) to obtain modified complex input sequence 

samples, where N is the number of audio samples in each of the first and second input 

sequences and n = 0, 

10 transforming the modified complex input sequence samples into a complex 

transform coefficient sequence Z k utilising a fast Fourier transform, wherein k « 

0,....,(M2-1); and 

post-processing the sequence of complex transform coefficients to obtain first and 
second sequences of audio coded frequency domain coefficients corresponding to the first 
15 and second audio channels Y k according to: 

G k = (Z k +Z^)/2 *»0.JW2-1 
G k = (Z k -Z^ x )/2j *-0JW2-l 

X k - cosy * ^cos(it(*+l/2)/^)^in(ir(/r+l/2)/A0 

- siny * ^sin(n(ik+l/2)/iV)^cos(it(^+l/2)/^ 

Y k = cosy * (g , v cos(n(*+l/2yJV)-g , J ^in(Tr(*+l/2)/iV) 

- siny * (g^sm^^l^ 

where G k is a transform coefficient sequence for the first channel; 

G\ is a transform coefficient sequence for the second channel; 
20 g K , and g Ki are the real and imaginary transform coefficient components of G k \ 

g\ r and g\i are the real and imaginary transform coefficient components of G\\ 
ZV*_, is the complex conjugate of Z N ^ t \ and 
y(Jt) = rc(2Jt+ l)/4. 
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